package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**=========================================================新增数据============================================*/
    @GetMapping("/saveData/{name}/{age}/{sex}")
    public AjaxResult insert(@PathVariable String name,@PathVariable Integer age,@PathVariable String sex){
        Review review = new Review();
        review.setName(name);
        review.setAge(age);
        review.setSex(sex);
        reviewService.insert(review);
        return AjaxResult.success("成功插入一条数据",null);
    }

    @PostMapping("/saveData")
    public AjaxResult insert(@RequestBody Review review){
        reviewService.insert(review);
        return AjaxResult.success("成功插入一条数据！",null);
    }

    /**=========================================================删除数据=============================================*/

    @DeleteMapping("/remove/{id}")
    public AjaxResult delete(@PathVariable Integer id){
        reviewService.delete(id);
        return AjaxResult.success("成功删除一条数据！",null);
    }
    /**=========================================================修改数据=============================================*/

    @PostMapping("/update")
    public AjaxResult update(@RequestBody Review review){
        Review updateReview = reviewService.getByID(review.getId().intValue());
        updateReview.setName(review.getName());
        updateReview.setAge(review.getAge());
        updateReview.setSex(review.getSex());
        reviewService.updateReview(updateReview);
        return AjaxResult.success("修改成功！",null);
    }
    /**=========================================================查询数据=============================================*/

    @GetMapping("/getById")
    public AjaxResult getById(Integer id){
        Review review = reviewService.getByID(id);
        return AjaxResult.success("操作成功！",review);
    }

    @GetMapping("/getDataByPage")
    public TableDataInfo getPageLimit(int pageNum,int pageSize){
        Integer allNum = reviewService.getAllNum();
        List<Review> pageLimit = reviewService.getPageLimit(pageNum, pageSize);
        TableDataInfo tableDataInfo = new TableDataInfo();
        tableDataInfo.setTotal(allNum);
        tableDataInfo.setCode(200);
        tableDataInfo.setMsg("查询成功！");
        tableDataInfo.setParams(null);
        tableDataInfo.setRows(pageLimit);
        return tableDataInfo;
    }
}